if (node == NULL)
return NULL;
- transform_node = gsk_transform_node_new (node, &state->data.transform.transform);
+ transform_node = gsk_transform_node_new_with_category (node,
+ &state->data.transform.transform,
+ state->data.transform.category);
gsk_render_node_unref (node);
void
gtk_snapshot_push_transform (GtkSnapshot *snapshot,
const graphene_matrix_t *transform)
+{
+ gtk_snapshot_push_transform_with_category (snapshot,
+ transform,
+ GSK_MATRIX_CATEGORY_UNKNOWN);
+}
+
+void
+gtk_snapshot_push_transform_with_category (GtkSnapshot *snapshot,
+ const graphene_matrix_t *transform,
+ GskMatrixCategory category)
{
GtkSnapshotState *previous_state;
GtkSnapshotState *state;
));
graphene_matrix_multiply (transform, &offset, &state->data.transform.transform);
+ if (previous_state->translate_x || previous_state->translate_y)
+ state->data.transform.category = MIN (GSK_MATRIX_CATEGORY_2D_TRANSLATE, category);
+ else
+ state->data.transform.category = category;
}
static GskRenderNode *
#include "gtksnapshot.h"
+#include "gsk/gskrendernodeprivate.h"
+
G_BEGIN_DECLS
typedef struct _GtkSnapshotState GtkSnapshotState;
union {
struct {
graphene_matrix_t transform;
+ GskMatrixCategory category;
} transform;
struct {
double opacity;
GtkSnapshot * gtk_snapshot_new_with_parent (GtkSnapshot *parent_snapshot);
+void gtk_snapshot_push_transform_with_category (GtkSnapshot *snapshot,
+ const graphene_matrix_t*transform,
+ GskMatrixCategory category);
G_END_DECLS
#endif /* __GTK_SNAPSHOT_PRIVATE_H__ */
#include "gtksnapshotprivate.h"
#include "gtkstylecontextprivate.h"
#include "gtktooltipprivate.h"
-#include "gtktransform.h"
+#include "gtktransformprivate.h"
#include "gtktypebuiltins.h"
#include "gtkversion.h"
#include "gtkwidgetpaintableprivate.h"
graphene_matrix_init_translate (&priv->transform, &GRAPHENE_POINT3D_INIT (adjusted.x, adjusted.y, 0));
gtk_transform_to_matrix (transform, &transform_matrix);
graphene_matrix_multiply (&priv->transform, &transform_matrix, &priv->transform);
+ priv->transform_category = gtk_transform_categorize (transform);
+ if (adjusted.x || adjusted.y)
+ priv->transform_category = MIN (priv->transform_category, GSK_MATRIX_CATEGORY_2D_TRANSLATE);
if (!alloc_needed && !size_changed && !baseline_changed)
{
GtkSnapshot *snapshot)
{
GtkWidgetPrivate *priv = gtk_widget_get_instance_private (child);
- gboolean needs_transform;
g_return_if_fail (_gtk_widget_get_parent (child) == widget);
g_return_if_fail (snapshot != NULL);
- needs_transform = !graphene_matrix_is_identity (&priv->transform);
-
- if (needs_transform)
- gtk_snapshot_push_transform (snapshot, &priv->transform);
+ gtk_snapshot_push_transform_with_category (snapshot, &priv->transform, priv->transform_category);
gtk_widget_snapshot (child, snapshot);
- if (needs_transform)
- gtk_snapshot_pop (snapshot);
+ gtk_snapshot_pop (snapshot);
}
/**
#include "gtkinvisibleprivate.h"
#include "gtkgesture.h"
+#include "gsk/gskrendernodeprivate.h"
+
G_BEGIN_DECLS
#define GTK_STATE_FLAGS_BITS 14
gint allocated_size_baseline;
graphene_matrix_t transform;
+ GskMatrixCategory transform_category;
int width;
int height;
int baseline;